草庐IT

postgreSQL 操作 教程

全部标签

go - Go 编译文件如何在不同的操作系统或 CPU 架构上工作?

由于我从昨天开始学习Golang:)我对编译后的文件有疑问。假设我编译我的项目。它在/bin文件夹中生成一个.exec文件。现在我的问题是,既然该文件是在基于IntelCPU的Mac上编译的,那么如果我想将它公开发布,它是否应该在其他操作系统和其他CPU架构(如AMD、ARM等)上编译?如果我在服务器上运行GOlang作为我的后端,我想这应该不是问题。但是,如果我发布我的.exec文件会发生什么,比方说在AWS上,有很多实例会根据负载自动增加/减少?有问题吗?编辑:对于那些正在寻找Go交叉编译工具的人来说,这是一个很好的解决方案https://github.com/mitchellh/

postgresql - Golang+PostgreSQL - 如何在不转义 HTML 标签的情况下打印精确查询?

存储在PostgreSQL中的数据:TheArgentineArmyis.数据类型:"content"textCOLLATE"default".通过Golang打印时,变成The<b>ArgentineArmy</b>is我需要在不转义HTML标记的情况下从PostgreSQL打印准确的数据。我不确定这是Go还是PostgreSQL的问题。下面是我的Golang代码:packagemainimport("database/sql""github.com/labstack/echo"_"github.com/lib/pq""html/template""io""l

postgresql - 如何参数化运算符?

我有如下的sql语句:SELECTpk,upFROMmytableWHERE2>1LIMIT10显然,这只是为了简单起见。我能够参数化任何整数:SELECTpk,upFROMmytableWHERE2>$1LIMIT10但是,当我尝试参数化运算符时,例如:SELECTpk,upFROMmytableWHERE2$11LIMIT10我得到:pq:syntaxerroratornear"$1"完整代码:packagemainimport("database/sql"_"github.com/lib/pq""log")funcmain(){log.SetFlags(log.Lshortfil

postgresql - Go database/sql 改变表名的大小写

我正在尝试使用database/sql和github.com/lib/pqPostgres驱动程序查询数据库。我遇到的错误是:pq:relation"itemprices_itemsale"doesnotexist但是看看我的查询:rows,err:=db.Query("SELECT*FROM\"itemPrices_itemsale\"LIMIT10")您会注意到表名中的大写“P”。我已经了解到,如果没有引用,Postgres会将名称折叠成小写字母。我引用了我的表名,所以我不太确定为什么会这样。我相当确定这就是问题所在,因为我能够使用类似Python程序中的表名查询表,并且一切都按预

go - 对项目集合执行操作

在我的实际代码中,我正在使用encoding/xml解析一个XML文档,我基本上有一堆如下形式的嵌套结构——所有这些都可能出现多次,除了顶级statements元素:statementsstatementopcodeargsprepost我是Go的新手,我显然误解了interface{}(空接口(interface))的工作原理:.\stmtgen.go:58:cannotuseprint_name(typefunc(Statement))astypefunc(interface{})inargumenttoperformAction.\stmtgen.go:58:cannotuses

postgresql - golang postgres 连接错误太多

我是Golang/Postgres的新手,我正在做一些测试并收到一个pq:sorry,toomanyclientsalready错误。我的postgres实例设置为最多100个连接,我在此代码中收到该错误fori:=0;i我通常可以插入大约60到70个插入然后我得到那个错误。所有连接都来自for循环中的那个样本。我做错了什么,这是我的完整代码。据我所知,1个连接可以容纳许多不同的查询,所以我不知道为什么它只给我60到70个插入然后得到错误。funcInsert_Stream(whttp.ResponseWriter,r*http.Request){wg:=sync.WaitGroup{

postgresql - 如何在 golang 中使用 .Format 将 time.Time 对象转换为格式化字符串?

我目前正在尝试从我的SQL数据库中获取一个time.Time对象,并将检索到的值转换为格式化字符串,如下所示:TIME_FORMAT:="%Y-%m-%dT%H:%M:%S"这是我在Python中用来做同样事情的格式,但我知道它不适合go。我已经从数据库中获取了值,现在只需要对其进行格式化。请注意,我已将ccc.Ia_date定义为interface{}类型,因为数据库中的此值可能为空。这是我的代码片段:fmt.Println(reflect.TypeOf(ccc.Ia_date))//givesmetime.Timet:=ccc.Ia_date//whichprintsas:2016

memory - 为什么使用单独的线程原子操作更快?

我有两段代码,桌面上有32个内核。代码A使用32个线程并执行以下操作,1)将值写入内存中的一些随机位置2)原子地向全局变量添加一个值。代码B使用16个线程将值写入随机位置,并使用另外16个线程以原子方式将值添加到全局变量。我想知道为什么代码B在每秒对全局变量执行多少原子操作方面更快。这里是代码Avarauint64=0constN=10*1024*1024vardata[N]uint64funcmain(){fori:=0;i这里是代码Bvarauint64=0constN=10*1024*1024vardata[N]uint64funcmain(){fori:=0;i

postgresql - 如何从go app查看postgresql "raise notice"

我正在用go编写小应用程序。现在我需要在应用程序控制台中记录postgres“raisenotice”消息。我没有找到postgresql在*sql.Conn中引发消息的地方(我使用go/sql和lib/pq驱动程序)例子,createfunctionshow_mes()returnsintas$$beginraisenotice'testmessagefrompg';return1;end$$languageplpgsql;我从goapp调用这个函数并可以得到结果。但是我如何从goapp访问消息“来自pg的测试消息”?在用Node编写的当前版本中,我们在控制台中记录消息以进行调试:谢

postgresql - golang/pq pq : operator does not exist: bigint = text

query:="WITHb(ColA,ColB)AS(VALUES($1,$2))UPDATEschema_name.table_nameASaSETColC=b.ColBFROMbWHEREa.ColA=b.ColAANDa.ColB=b.ColB"res,err:=db.Exec(query,1,1)上述代码失败并出现以下错误:pq:operatordoesnotexist:bigint=text“ColC”是BIGINT类型。根据我的调查,驱动程序将值作为文本而不是整数插入。问题:https://github.com/lib/pq/issues/582